Module 11 : La gestion des performances 


ATELIERS 











KR Ee a a 10mn 
Tâche 2 : Surveiller une commande avec time... 10mn 
Tâche 3 : Surveiller le système avec la commande sar ......essosssossossossesssssessssssessess 10mn 
Tache E E EU ee dans 10mn 
Tâche 5 : Surveiller le système en pénurie de ressources Smn 
Tache ERT EN E 10mn 
Taché 7: Modifier les'paramètres du NOYAU eege 5mn 
Tâche 8 ` Simuler une charge avec un benchmark, l’influence de la mémoire... 15mn 

Tâche 1 : 

Surveiller le système 


1. Activer les principales commandes de surveillance natives et observer les types d’informations 
recueillies. 
[root@linuxl ~]# uptime 
12:46:29 -up 13 days, 14:13, -2 users, load average: 0:00; 07007 0-00 
froot@linuxl -]# free 


total used free shared buffers cached 

Mem: 449908 444876 5032 0 62376 309356 

=/+ buffers/cache: 73144 376764 

Swap: 522072 0 522072 

[rootêlinuxl -]# vmstat 

ONE merite ares MONO Ye semer SEAL == men Lomme. systeme == Ee 
rp swpa---free- -buff cache si 506 bi bo in cs us sy id wa 
0 0 05032 62380: 309356 Q 0 1 L'oeil 33:-0--0-100 0 
[root@linuxl -]# vmstat 5 3 

DOCS erg DOTE em nn more SWAD ee Res EE Clees PU 
LD SpA free- buff- cache ai so bi at CS us sy id wa 
DO D 5032 -62394 309356 0 0 + Sg, EE GE E Eau en 
D 0 0 --5032 62384 309356 0 0 D 6 1042 120 GD Ion 0 
0 © 0 5032 62384 309356 0 0 0 G-1061-167""0" 071000 


[root@linuxl ~] w 
12:46:56-up-13-däys; 14:13, 2 users, load average: 0.00, 0.00, 0.00 


USER TTY. FROM LOGING IDLE JCPU PCPU WHAT 

root ttył = 22Jan07 12däys -0.01s 0.01s -bash 
root pts/1 raichu.pokemon  Tuëé15 0.005 0:275 0.008 w 
[root@linuxi -]# ps aux | head 

USER PID $CPU %MEM VSZ RSS- TTY STAT START TIME COMMAND 
root det S Jan21 0:00-init-[5] 
root SH DC DO 0 0°? SN-Jan21 0:14 {ksoftirqd/0] 
root EE E 0 D? Se danzt 0:00 [events/0] 
root &0:0--D:0 Q EES S< Jan21 0:00 fkhelper] 
root 30-900 0 0? Se * Jan?21 0:00 [käċpid] 
root Si HD CD 0 0:-? Se Jan21 0:00 [kblockd/0] 
root 50:-0:0:--0:0 0 0:2 S<- Jan21 - 0:00 [aio/0] 
root 300-0070 Q 0 ? S Jan21 0:00 [khuba] 
root 49--0:0--0.,0 0 WR S Jan21 0:00 f[kswapd0]) 


[root@linuxi -]# netstat -i 
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Kernel Interface table 


Iface MTU Met RX-OK RX-ERR RX-DRP RX-OVR TX=OK TX-ERR TX-DRP TX=-OVR 
Fig 

eth0 1500 0::::222799 Q 0 0 18335 0 0 D 
BMRU 

eth0:1 1500 0 = no statistics available - 

BMRU 

Lo 16436 (e) 3179 0 0 D 3179 0 0 D 
LRU 


[root@linuxl -]# top 

top — 12:50:59 up 13-days, 14:17, 2 users, -load average: 0.51, 0.12, 0.04 
Tasks::  54-total, 2 running, 52 sleepinig, 0 stopped, D zombie 

Cpu(s):: 0.098 us, D.0ë su, O00 ni, 100:0%-id;--0.:0% wa, -0.0%-h1; -0.0% si 


Men: 449908k total, 445132k used, 4776k free, 62392k buffers 
Swap: 522072k total, Dk used, 522072k free, 309496k cached 
PID USER PR "NI -VIRT RES -SHR S SCHU SMEM TIME+ COMMAND 
1 root 16---0—-3084--552-472-8—-0-:07--051----0700-66"inTt 
2 root RE. Q 0 0 S 0.0 0.0 -0:14.28 ksoftirqd/0 
3 root 5-=10 0 D DS 0.0 -0-0 — 0:00.00 events/0 
4 root LI --10 OD 0 DS 0000 0:00.01 khelper 
BD root CLIS 0 D O0 S “0.0 0.0 0:00.00 kacpid 
29-ro0t 5 -10 W 0 0-S--0.0 0:0---0:00.00 kblockd/0 
50 root Pet 0 D OS 0000 0:00.:00 aio/0 
30 root 15:70 0 9 DS 0.0--0.0---0:00,06:khubd 
49 root Sr 0 0 0°S 0.0: 0.0 —-0:00.19 kswapd0 
196: root Le mla e 0 0 DS 0.0 0.0 0:00.00 kseriod 
318 root 15 0 D 0 E SE ele 0:00:22"kjournald 
1473- root 10 -10- 2176 468--380-S— 0-0- 0.1 0:00.01 udevd 
2115 root EES 0 D DS 0.0--0:0.- 60:00:00 scesi-eh 0 
2116 root 15 0 0 0 ee AE 1:18.07 Usb-storage 
2609 root Gett 0 D 0 S 0.0 0.0 0:00.00- kauditd 
2650 root 6 -10 0 0 0-S:-0:0::0:0: 0:00 00kmirrord 
2681 root Seet 0 0 DS op DD 0:00.00 kjournald 


Remarque : La commande top affiche la charge système, l’utilisation de la mémoire et les processus 
les plus consommateurs de ressources (CPU, %MEM). La commande est rafraîchie périodiquement. 
On arrête la commande par Ctrl-C. 

froot@linux1 -]# top -b -d 10 -n 4 >> fic 

[root@linuxl -]# head fic 

top — 13:03:10 up 13 days, 14:29, 2 users, load average: 0.02, 0.37, 0.32 
Tasks: 54 total, 1 running, Bä sléeping, D stopped, 0 zombie 

Ciel: 0.1% us, 0.0$ sy,;--0:0%-ni;-99:8%-1d, :0-0$"wa,;-0.0$-h1, 0.0$ si 
Mem: 449908k total, 445260k used, 4648k free, 62464k buffers 

Swap: 522072k total, Dk used, 522072k free, 309520k cached 





PID USER PR "MI VIRT RES SHR- S SCHU SMEM TIME+ -COMMAND 
1 root 160" 3084:-552-- 472-500-0510: 00-660 D n 
2-root RE Le e 0 o 0 S 0.0 0.0 0:14.28 ksoftirqd/0 
3: root St 0 D 0S 0.0 0.0 0:00:00 events/0 
[root@linuxl -]# 








Remarque : On vient d’utiliser top en mode « batch ». On a fait 4 mesures à 10 secondes d’intervalle. 


[root@linux1 -]# watch free 
Every 2.0s: free Sun Feb 4 13:04:50 2007 
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total used free shared buffers cached 
Mem: 449908 445452 4456 D 62472 309584 
-/+-buffers/cache: 73396 376512 
Swap: 522072 0 522072 








Remarque ` On arrête la commande par Ctrl-C. 


2. On utilise les commandes du package systat (sauf sar). 
{root@linuxi -]# rpm -q sysstat 
sysstat-5.0.5-11.rhel4 

froot@linuxl -]# rpm -ql sysstat | grep bin 
/üusr/bin/iostat 

/usr/bin/mpstat 

/usr/bin/sar 

[root@linuxi -]# yum provides iostat 


sysstat.1386 5.0.5-11.rhe14 installed 


{root@linuxi —-]# mpstat 


Linux 2.6.9-42.EL (linuxl.pinguins) 02/04/07 

13:53:28 CPU. user nice system $iowait girq $soft idle 
intr/s 

13:53:28 all 0.07 0.00 0.04 0.04 0.02 0.00 99.83 
1050.55 

[root@êlinuxl -]# iostat 

Linux 2.6.-9-42.EL (linuxl.pinqguins) 02/04/07 

avg-cpu: -$user $nice Saus $iowait idle 


0:07 0:00 0.05 0:04:---99583 


Device: tps. Bik read/s--BIK wrtn/s-Blk read BIik wrtn 
hda 0.12 de 1.74 1787853 2048820 
hdal 0.00 0.00 0.00 1370 30 
hda2 0.26 1.49 1.71 1755778 2015048 
hda3 0.00 0.00 0:00 1411 76 
hdas 0:00 0.00 0.00 1074 0 
hda10 0.01 0.02 0:03 20970 33650 
hdc 0.00 0.01 0:00 12636 H 


3. Installer et utiliser procinfo. 

[root@linuxl ~]# wget 'http://downloads .sourceforge.net/mcj/procinfo-18.tar.bz2’ 
[root@linuxi ~]# tar xvjf procinfo-18.tar.bz2 

procinfo-18/ 
procinfo-18/1sdev.8 
procinfo-18/procinfo. 
procinfo-18/procinfo. 
procinfo-18/procinfo: 
procinfo-18/routines. 
procinfo-18/socklist. 
procinfo-18/1sdev.pl 
procinfo-18/socklist.pl 
procinfo-18/procinfo.lsm 
procinfo-18/README 


on Do o 
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procinfo-18/CHANGES 

procinfo-18/Makefile 

{root@linuxl <]# cd procinfo-18 

{[root@linuxl procinfo-18]# ls 

CHANGES README isdev.pl procinfo.c: procinfo.lsm -socklist.8 
Makefile lsdev.8 procinfo.8 procinfo.h routines.c socklist.pl 
[root@linuxl procinfo-18]# make 

gcc -Wall -Wstrict-prototypes -02 _-C -o procinfo.o procinfo.c 
procinfo.:c:19: warning: 'rcsid! defined but not used 

gcc Mall -Wstrict-prototypes. -02 =C -0 routines.o routines.c 
routines.c:19: warning: 'rcsid' defined but not used 

gc Mall -Wstrict-prototypes -s  procinfo.o routines.0 =I1termcap =o procinfo 
[root@linuxl procinfo-18]# make install 

mkdir -p /usr/bin 

install procinfo /usr/bin/procinfo 

install isdev:pl:/usr/bin/lsdev 

install socklist.pl /usr/bin/socklist 

mkdir -p /usr/man/man8 

install =m 644 procinfo.8 /usr/man/man8/procinfo.8 

install -m 644 Ilsdev.8 /usr/man/man8/lsdev.8 

install -m 644 socklist.8 /usr/man/man8/socklist.8 

[root@linuxl procinfo-18]# procinfo 

Linux 2.6.9-42.EL (buildcentos@build-i386) (gcc.3.4.6 20060404} #1 -1CPU 


[linux1] 

Memory: Total Used Free Shared Buffers 
Mem: 449908 371636 78272 0 55740 
Swap: 522072 0 522072 


Bootup: Sun Jan 21 22:33:28 2007 Load average: 0.00 0.00 0:00 1/54-15738 


user : 0:08:47.63 0:0%- page in : 0 

nice: 0:00:00.32 °° 0.0% page out: o 

system: 0:06:00.92 0.0% swap in : 0 

idie 24 -14:40:16.99 -99.9% ` swap out: Q 

uptime : 24 15:04:59.20 context :154378682 

irq 0:1086255246 timer LEd:-12: 85 i8042 
E 145 i8042 irq 14: 115924 ide0 
STE 6 TE 9773947 idel 
EES 2 irq169: 214956 eth0 
Ee 4 irq185: 44604067 ehci hcd, uhci hcd, 
Tite: Lis irgq193: 07 VIA8233 
Er 9 D acpi 


froot@linux1 procinfo-18]# ed 


4. Créer un script de surveillance activé par un crontab. 
[root@linuxl ~}# vi surveille.sh 

{root@linuxl -]# cat surveille.sh 

#!/bin/sh 

uptime 

EES 

ps aux Leort -rk +3 | head -10 
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{root@linuxi -}# chmod u+x surveille.sh 
[root@linux1 -]# crontab -1 > /tmp/new cron 
no crontab for root 
[root@linuxi ~}# echo "* * * * * /root/surveille.sh > /var/log/perf.log 2>&1" >> 
/tmp/new_cron 
[root@linux1 -]# crontab /tmp/new cron 
[root@linuxl -]# head /var/log/perf£.log 
14:06:01 up 13 days, 15:32; 2 users, toad average: 0:00, 0.00, 0:00 


total used free shared buffers cached 
Mem: 449908 403816 46092 0 61948 268180 
-/+ buffers/cache: 73688 376220 
Swap: 522072 D 522072 
USER PID SCHU %MEM Ve CN weg STAT START TIME COMMAND 
gdm 4498. 0.0 2.3 21264 10348 ? Ss Jan21 0:00 
/usr/bin/gdmgreeter 
root 4155 0.0 1.9 11944 8600 ? S Jan21 0:00 /usr/X11R6/bin/X 
:0 -audit D -auth /var/gdm/:0.Xauth -nolisten tcp vt7 
root 3428:--0:0:--1:7--11364--7952:? Ss Jan21 7:55 -hald 
root 4133 0.0 0.5 12892 2432 ? S Jan21 -0100 /usr/bin/gdm- 


binary -nodaemon 


Tâche 2 : 
Surveiller une commande avec time 


1. Créer un programme consommateur de CPU (calcul de la constante mathématique e). 
[root@linuxi ~]# vi e.py 
# calcul de € 
import sys 
on ch ="1" 
for i in range(int(sys.argv{1})): 
HEEM 


un =-int(un_ch) 
esun + un 

n = 1 
factorielle = 1 


while 1: 
S a AAAS $ e ma k 
factorielle = factorielle * n 
e-old =-e 
e = e + un/ factorielle 
AË e == epla- break 
print -léssai-n-5","h,-" és", 6 


2. Utiliser la commande time interne. 
[root@linux1i ~]# time python e.py 10 
essai nz Lä e = 27182818277 


real Om0.015s 
user Om0.011s 
sys Om0.005s 





Remarques : 
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1) Le script de calcul de e demande en argument le nombre de décimal voulu. 
2) Le temps réel est le temps pour l’être humain. Le temps CPU consommé est user+sys. 


3. Utiliser la commande time externe (GNU). 

{root@linuxl -]# /usr/bin/time python e.py 100 

essai n : 70 ess 
27182818284590452353602874713526624977572470936999595749669676277240766303535475 
945713821785251664238 


0.00user 0.00system 0:00.01elapsed 86%CPU (0avgtext+0avadata Omaxresident)k 
Oinputs+0outputs (0major+601minor)pagefaults Oswaps 


4. Idem, mais en affichant plus d’informations. 

[root@linuxl -]# /usr/bin/time -v python e.py 100 

essai nz :70-e = 
27182818284590452353602874713526624977572470936999595749669676277240766303535475 
945713821785251664238 


Command being timed: "python e.py-100" 
User time (seconds): 0.01 
System time (Seconds): 0.00 
Percent of CPU this- job got: 80% 
Elapsed ‘(wall clock) time (h:mm:ss Or m:$5): 0:00:01 
Average shared text size (kbytes):-0 
Average unshared data size (kbytes): 0 
Average Stack size (kbytes): D 
Average total size (kbytes): 0 
Maximum resident set size (kbytes): 0 
Average resident set size (kbytes): 0 
Major (requiring 1/0) page faults: 0 
Minor (récläiming a frame) page faults: 581 
Voluntary -context switches: 1 
Involuntary context switches: 3 
Swaps::0 
File system inputs: 0 
File systém outputs: 0 
Socket messages sent: 0 
Socket messages received: 0 
Signals delivered: 0 
Page size (bytes): 4096 
Exit status: 0 

froot@linux1 ~]# 


Tâche 3 : 
Surveiller le système avec sar 
1. Utiliser en direct la commande sar. 


Dans les exemples suivants, on fait trois mesures à cinq secondes d’intervalle. 
[*oot@linuxl -]# sar -u 53 


Linux 2.6.9-42.EL (linuxi.pinguins) 02/04/07 

14:30:03 CEO $user $nice  $system ` $iowait zidle 
14:30:08 all 0:00 0.00 0.00 0.00 100.00 
14:30:13 ail 0.00 0.00 0:00 0.00 100.00 
14:30:18 all 0.00 0.00 0700 0:00 100.00 
Average: all 0-00 0:00 0.00 0.00 100:00 
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Remarques : 
1) La somme $user+$%nice+%system donne le pourcentage d'utilisation des processeurs. 
2) La somme %iowait+%idle donne le pourcentage d'inactivité des processeurs. 


3) Le rapport $user/%system indique si le système fait globalement des calculs ou des IO. 
[root@linuxt ~] sar -q 5-3 


Linux 2.6.9-42.EL (linuxt-pinguins) 02/04/07 

14:30:30 rung-s2 plist-sz Idavg-1 idavg-5- ldavg-15 
14:30:35 0 55 0:00 0.00 0.00 
14:30:40 0 55 0.00 0.00 0.00 
14:30:45 0 55 0:00 0.00 0.00 
Average: 0 55 0:00 0:00 0.00 





Remarque : plist-sz indique le nombre total de processus. rung-sz Indique le nombre de 
processus en attente d’un processeur. 





froot@linux1 =]# sar =r 5 3 
Linux 2.6.9-42.EL-(linuxl.pinquins) 02/04/07 


14:31:49 kbmemfree kbmemused imemused kbbuffers “kbcached kbswpfree 
koswpused $swpused  kbswpcad 


14:37:54 46476 403432 89.67 61980 268232 522072 
0 0:00 Ô 

14:31:59 46476 403432 89.67 61980 268232 522072 
D 0.00 0 

14:32:04 46220 403688 89:73 61980 268232 522072 
D 0.00 Q 

Average: 46391 403517 89.69 61980 268232 522072 
0 0.00 0 

[root@linuxt -]# ear -b 5 3 

Linux 2.6,9-42.EL {linuxi pinguins) 02/04/07 

14:32:30 tps rtps wtps  bread/s bwrtn/s 

14:32:35 0.00 0.00 0.00 0.00 0.00 

14:32:40 0:00 0:00 0:00 9.00 0.00 

14:32:45 0.00 0:00 0:00 0.00 0:00 

Average: 0.00 0.00 0.00 0.00 0:00 





Remarque : tps indique le nombre de transfert entre la mémoire et les disques physiques. rtps 
indique le nombre de lectures et wtps le nombre d’écriture. bread/s indique le nombre de blocs de 
512 octets lus par seconde et wrtn/s le nombre de blocs écrits par seconde. 





[root@êlinuxl -]# sar -B 5 3 


Linux 2.6.9-42:EL (linuxl.pinguins) 02/04/07 

15:00:36 pgpgin/s pgpqout/s  fault/s majflt/s 
15:00:41 0:00 7.19 9.98 0.00 
15:00:46 0.00 0.00 6.20 0.00 
15:00:51 0.00 0:00 2:00 0.00 
Average: 0.00 2.40 6.07 0.00 


Remarque ` pgpgin/s et pgpgout /s indiquent les transferts en Ko entre la mémoire et le disque. 
fault/s indique le nombre de défaut de page par seconde. maj f1t/s indique le nombre de défauts 
de page qui entraînent une lecture disque. 
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[root@linuxl -]# sar -R 5 3 


Linux 2.6.9-42.EL (linuxi.pinguins) 02/04/07 
15:08:07 frmpg/s: bufpg/s - campg/s 
15:08:12 0.00 0.00 0:00 
15:08:17 0.00 0.09 0.00 
15:08:22 0.00 0.00 0:00 
Average: 0.00 0.00 0.00 








Remarque : frmpg/s indique le nombre de pages libérées par seconde. Une valeur négative que le 
système alloue des pages. bugfpg/s indique l’augmentation d'allocation de pages en tant que 
tampon disque (buffer). Une valeur négative montre une diminution de ces tampons disques. 





[root@linuxl -]# sar W53 


Linux 2.6.9-42.EL (linuxl.pinguins) 02/04/07 
15:08:49 pswpin/s pswpout/s 
15:08:54 0.00 0.00 
15:08:59 0.00 0:00 
15:09:04 0.00 0.00 
Average: 0.00 0:00 





Remarque ` Nombre de page-in par seconde (pswin/s) et de page-out par seconde (pswpout/s). 


[root@linuxl -]# ps -e |grep cupsd 


16810? 09:00:00 cupsd 

[root@linuxl -]# sar -x 16810 5 3 

Linux 2.6-9-42-.EL-(linuxl-pinguins) 02/04/07 

15:19:54 PID minflt/s majfit/s $üser system nswap/s. CPU 
EE 16810 0.00 0.00 0.00 0.00 0.00 0 
15:20:04 16810 0.00 0.00 0-00 0:00 0.00 0 
15:20:09 16810 0.00 0.00 0.00 0.00 0:00 D 
Average: 16810 0.00 0.00 0.00 0:00 0.00 
[root@linuxt -]# sar -v 5 3 

Linux 2.:6.-9-42 EL (1inuxl-pinguins) 02/04/07 


15:20:44 dentunusd' file-sz ‘inode-sz  super-sz $super-s2  dquot-sz $dquot- 
SZ Cales $rtsig-sz 


15:20:49 26708 780 26625 0 0.00 0 
0.00 0 0.00 

15:20:54 26708 780 26625 0 0.00 0 
0.00 D 0.00 

65:20:59 26708 780 26625 Q 0:00 0 
0.00 0 0.00 

Average: 26708 780 26625 (el 0.00 D 
0.00 0 0:00 

[root@linuüuxl =]# sar -c 5 3 

Linux 2.6.9-42.EL (linuxl.pinguins) 02/04/07 

15:22:28 proc/s 

15222233 0.00 

15522:38 0.00 

15:22:43 0.00 

Average: 0.00 





Remarque : proc/s indique le nombre de processus créés par seconde. 
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[root@linuxi Jä sar -n DEV 5 3 


Linux-2.6.9-42.EL (linuxl,pinguins) 02/04/07 

Average: IFACE-- rxpck/s - txpck/s---rxbyt/stxbyt/s - rxcmp/s 
Etxcmp/s rxmcst/s 

Average: lo 0-00 0:00 0:00 0.00 0:00 
0.00 0.00 

Average: eth0 0.60 0.33 60.57 75-42 0.00 
0.00 0.00 

Average: sit0 0.00 0:00 0-00 0:00 0:00 
0.00 0.00 


2. Collecter les données de sar. 

{root@linuxi -j# crontab =e 

crontab: installing new crontab 

{root@linuxi -}# crontab -1 

*/20 17-20 — — ZS Zusr/iib/aaisal 300 4 & 
5 23 Æ £ x /usr/lib/sa2 -A & 
[root@linuxl 18 


Remarque ` En argument de sal on indique un intervalle et un nombre de mesures. Dans l’exemple 
sal est activé toute les 20 minutes. A chaque fois il fait 4 mesures à 300 secondes (5 minutes) 
d'intervalle, ce qui donne un total de 20 minutes. 





3. Visualiser les données récoltées (il faut attendre au moins 5 minutes). 
[root@linuxl -j# sar 


Linux 2.6.9-42.EL (linuxl.pinguins}) 02/04/07 

00:00:01 CPU guser $nice Ssystem  $iowait $idle 
00:10:01 all 0.03 0.00 0.03 0.00 99.94 
00:20:07 all 0.03 0.00 0:03 0:00 99:94 





Remarque ` Par défaut, sar utilise l’option — et visualise les données récoltés dans la journée. 


[root@linuxl -]# Le /var/log/sa/ 


sa04 

[root@linuxl -]# sar -u -f /var/log/sa/sa04 

Linux 2:6.9-42.EL (linuxl.pinguins) 02/04/07 

00:00:01 CPU $user $nice $system $iowait $idle 
00:10:01 all 0.03 0:00 0:03 0-00 99.94 
00:20:01 all 0.03 0.00 0.03 0.00 99.94 


Remarque ` Avec l’option -£, on peut voir les données récoltés un jour quelconque. Dans l’exemple, 
les données du 4ième jour du mois. 


Tâche 4 : 
La comptabilité 


1. Est-ce que le paquetage de comptabilité est installé ? 


[root@linuxl <]# rpm =q psacct 
psacct-6,3.2-38.rhel4 


2. Quel est le fichier comptable ? 
[root@linuxl -]# more /etc/init.d/psacct 


# The location of the accounting file 
ACCTFILE=/var/account/pacct 
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Start { 
[ ! -r SACCTFILE ] Sp touch SACCTFILE gé chmod- 600 SACCTFILE 
action $"Starting process accounting: H /sbin/accton SACCTFILE 


touch /var/lock/subsys/psacct 


Stop { 
action $"Shutting down process accounting: “-/sbin/accton 
rm -f:/var/lock/subsys/psacct 


3. Démarrer le service. 

[root@linuxl -]# /etc/init.d/psacct start 

Activation de la gestion des processus : ee SE 
[root@linuxl -]# 


4. Dans une autre session, se connecter en tant que guest pour générer des enregistrements 
comptables. 

login as: guest 

Sent username "guest" 

guest@192.168.218.99's password: wwiii945 

Last login: Sun Feb 4 08:57:53 2007 from raichu.pokemon 

[guest@linuxl -]$ date 

dim fÂ©v 4 09:06:48 CET 2007 

[guest@linuxl ~]$ who 


root ttył Jan-22 20:30 
root DS Jan 30 15:20- (raichu.pokemon) 
guest pts/2 Feb 4 09:06 (raichu.pokemon) 


fguest@linuxi ~]$ uptime 
09:06:54 up 13 days, 10:33, 3 users, load average: 0.00, 0:00,-0.00 
fguest@linuxl ~]$ exit 


5. Lister les totaux de connexions. 
[root@linuxl -]# ac 
total 0.01 


6. Lister les totaux de connexions par jour. 
froot@linuxl -]# ac -d 
Today total 0:01 


7. Lister les totaux de connexions par utilisateur. 
[root@linuxt -]# ac -p 
guest 0.01 
total 0.01 


8. Lister les totaux d’utilisation du CPU par commande. C’est l’option par défaut de la 
commande sa. 
[root@linuxl -]# sa 


42 2.43re 0.00cp 1054k 

12 1:53re 0.00cp 1005k ***other 
12 0.00re 0-00cp 1186k-bash* 

6 0.00re 0.00cp 1001k id 

4 0.00re 0:00cp F10k---ac 

2 0.90re 0.00cp 1882k- ssbdz 

2 0.00re 0.:00cp 1296k initlog 
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2 0:00re 0.00cp 796k- grep 
2 0.00re 0.00cp 592k  egrep 


9. Afficher les totaux d’utilisation du CPU par utilisateur. 
froot@linuxi ~]# sa -m 


43 2.43re 0.00cp 1041k 
guest 31 1.25ré 0.00cp 1039k 
root LI 0.9ire 0.00cp 986k 
sshd 1 0.28re 0:00cp 1723k 
10. Afficher l’utilisation du CPU pour toutes les commandes enregistrées, l’utilisateur est 

mentionné. 
[root@linuxi -]# sa -u 
root 9.00 cpu 331k mem accton 
root 0:00 cpu 1334k mem initliog 
root 0:00 cpu 1259k mem initiog 
root 9.00 cpu 1263k mem touch 
root 0:00-cpu 1195k mem psacct 
root 0.00 cpu 700k mem ac 
sshd 0.00 cpu 1723k mem sshd $ 
Ouest 0.00 cpu 532k mem id 


11. Afficher les données brutes. 
[root@linuxi IS lastcomm 


sa S root pts/1 0.00 secs Sun Feb A 09:10 
crond SE root ER 0.00 secs Sun Feb 4 09:10 
sadc S Foot Se? 0:00 secs- Gun Feb” d 09:10 
date S root EE 0.00 secs Sun Feb 4 09:10 
sa S root pts/i 0.00 secs Sun Feb 4 09:09 
sa S root pts/1 0.00 secs Sun Feb A 09:09 
12. Idem, mais concernant uniquement un utilisateur. 

[root@linuxi -}# lastcomm guest 

sshd SF guest ES 0.00 secs Sun Feb 4 09:06 
bash guest pts/2 0.01 secs Sun Feb 4 09:06 
clear guest pts/2 0.00: secs Sun Feb 4 09:07 
uptime guest pts/2 0.00 secs Sun Feb 4 09:06 
who guest pts/2 0.00 secs Sun Feb A 09:06 
date guest pts/2 0.00 secs Sun Feb A 09:06 


13. Arrêter le service. 

[root@linuxl -]# /etc/init.d/psacct stop 

ArrÂ°t de la gestion des processus : EG 
[rootélinuxl 238 


Tâche 5 : 
Surveiller le système en pénurie de ressources 


1. Créer des commandes pour consommer des ressources. 

[root@linuxl -]# vi charge cpu.sh 

{ peri -e ‘'$var=2.5S;while(l){$var*=3;S$var/=3;}" & sleep 10;:ki11 $!; } & 
[root@linuxl -]# vi charge mem.sh 

{ perl -e 'for($i=0;$1<100000000;$1i++) {Stb[$il=$i;}" & sleep 10;kill $!; } & 
[root@linuxl <]# vi charge io.sh 


{ find / -type f -print -exéc grep -i Linux {} \; >/dev/null 2>&1 & sleep 
10;k111-$1;-+ € 
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ATTENTION : NE PAS UTILISER CES COMMANDES SUR UN SYSTEME EN 
EXPLOITATION ! 





2. Activer les commandes de simulation de charge et de surveillance en même temps. 
[root@linuxl ~]# { sleep 10; sh charge mem.sh & sh charge cpu.sh & sh 
charge io.sh & } & 


{4} :30019 

[root@linuxl -]# vmstat 10 5 

procs Tree EE eg HE syster ees Le 
CD swpd free buff cache si so bi bo in cs us sy id wa 
DR 0-150292 -55744-182292 0 Q d $ 0 340: "0:-100--0 
d 0 0-116692 55744 182340 0 D 2 4-1052;:;-248-19---3:78-0 
0 D 0 196236 55632 140596 D ER E ee E e E ER 
00 0 196364 55632 140596 0 0 D ELO 
D D 0 196428. 55632 140596 0 0 0 Et-1053;:..143- "0-0" 1000 
{1}]+ Done {sleep 10; sh charge mem.sh & sh charge cpu.sh € 


sh charge-io.sh e} 





Remarque : On peut utiliser d’autres commandes de surveillance au lieu de vmstat. 





Tâche 6 : 
Limiter l’usage des ressources 


1. Limiter les ressources avec ulimit. 

[root@linuxi -]# ssh -1 guest localhost 
quest@localhost's password: wwiii945 

Last login: Sun Feb 4 09:06:46 2007 from raichu.pokemon 
[guest@linux1 ~}$ ulimit -a 


core file size (blocks; -c) 0 

data seg size (Xkbytes, -d) unlimited 
file size (blocks, ~f} unlimited 
pending signals t-i) 4024 

max locked memory (kbytes, =1) 32 

max memory size (kbytes; -m) unlimited 
open files (-n) 1024 

pipe size (512 bytes, -p) 8 

POSIX message queues (bytes, -q) 819200 
stack size (kbytes, =s) 10240 

cpu time (seconds, -t} unlimited 
max user processes om à à MS NC o 
virtual memory (kbytes; =v) unlimited 
file -locks (-x) unlimited 


fquest@linux1 -]$ ulimit -S -m 32 


Remarque : On limite la limite soft de la taille mémoire à 32 Mo. 
fguest@linuxl -]$ ulimit -u -m 


max user processes Gol 715 
max memory size (kbytes, =m) 32 
[guestêlinuxl JS ulimit -m 

32 


[guest@linuxl -]$ perl -e 'for($i=0;$i<1000000000:$i++) {$tb[$i]=$i;}" 
Out of memory! 
fquéstElinuxt -]$ free 
total used free shared buffers cached 
Mem: 449908 25020 424888 9 252 7240 
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=/+ buffers/cache: 17528 432380 
Swap: 522072 24180 497892 
[guest@linuxl ~]$ ulimit -S -u 5 


Remarque : On limite à 5, le nombre de processus simultané pour guest. 


[guest@linuxl -]$ ulimit -u -m 

max user processes CO) 5 

max memory size (Kbytes, -m) 32 
[guest@linux1 IS ulimit -u 

5 

[quest@linuxl -]$ sleep 10 & sleep 10 & sleep 10 & 
ULI 32055 

[2] 32056 

DI 32051 

[guest@linuxl ~]$ sleep 10 & 

bash: fork: Ressource téemporäirement non disponible 


Remarque : l’activation d’un cinquième processus (ne pas oublier le shell), échoue. 
[(guest@linux1 -]$ ulimit -u unlimited 

bash: ulimit: max user processes: cannot modify limit: OpA©ration non permise 
Iguest@linuxl =]$ ulimit -u 751 

[guest@linuxl ~]$ ulimit -m unlimited 

[quest@linuxl ~]$ ulimit -u -m 

max user processes Got 751 

max memory size (kbytes, -m)-unlimited 

fguest@linux1 IS ulimit -m 32 

[guest@linuxl -]$ export LANG=C 

[quest@linuxl -]$ ulimit -m unlimited 

“bash: ulimit: max memory size: cannot modify limit: Operation not permitted 
[quest@linuxl ~]$ ulimit =m 64 

-bash: ulimit: max mémory size: cannot modify limit: Operation not permitted 
[guest@linuxl -]$ exit 


Remarque : Quand on modifie la limite hard, on ne pas revenir en arrière (pour cette session). 


2. Limiter les ressources de guest à chaque connexion. 
[root@linuxl -]# cp /etc/security/limits.conf /etc/security/limits.conf .000 
[root@linuxi -]# vi /etc/security/limits.con£f 


#e@student = maxlogins 4 


guest x maxlogins 1 
guest hard nproc 


# End of file 


Remarque : On ajoute les lignes en italique. 


[root@linuxl ~]# ssh -l guest localhost 

guest@localhost's password: wwi+1945 

Last login: Sun Feb A 17:02:10 2007 from localhost:localdomain 
[guest@linuxl -]$ sleep 30 & sleep 30 & sleep 30 & 

{1]-32104 

LI 32105 

{3}-32106 

[gquest@linuxl -]$ sleep 10 E 

“bash: fork: Ressource temporairement non disponible 
fauest@linuxl--]$ 
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A partir, d’un autre terminal, on essaye de se connecter, cela échoue. 
[root@linuxl -]# ssh -1 guest localhost 
guest@localhost's password: wwii1945 

Read from remote host localhost: Connection reset by peer 
Connection to localhost closed. 


On remet la configuration d’origine. 

[root@linuxl -]# cp /etc/security/limits.conf.000 /etc/security/limits.conf 
cp: overwrite  /etc/security/limits.conf'? y 

[root@linuxl -]# 


3. Supprimer la mise à jour des dates de derniers accès. 

[root@linuxi -]# dd if=/dev/zero of=/root/GROS PIC bs=1k count=100000 
100000+0 records in 

100000+0 records out 

{root@linux1 -]# mkfs -q -F /root/GROS FIC 

[root@linuxl ~]# mount -o loop /root/GROS FIC /mnt 

{root@linuxl =] cal > /mnt/f1 


On attend un peu (deux minutes environ). 

[root@linuxl -]# cat /mnt/f1 > /dev/null 
{root@linuxl -]# 1s -1 /mnt/f1 

=IW-r--r-— 1 root root 137 Feb A 17:40 /mnt/f1 
{root@linux1 -]# ls -lu /mnt/f1 

=XwW-r--1-- 1 root root 137 Feb 4"17:41-/mnt/f1 


Remarque : La lecture du fichier à provoqué la mise à jour de la date de dernier accès et donc à 
provoqué UNE ECRITURE SUR LE DISQUE ! 





On recommence l’exercice mais en désactivant la mise à jour des dates de dernier accès. 
[root@linuxl -]# umount /mt 

[root@linuxl -]# mount -o loop,noatime /root/GROS FIC /mnt 
froot@linux1i -]# date 

Suñ Feb 4- 17:46:52 CET 2007 

[root@linuxl -]# cat /mnt/£f1 > /dev/null 

{root@linuxi -]# ls -lu /mnt/f1 

=EW-r=-r-— l root root 137 Feb 4 17:41 /mnt/f1 

[root@êlinuxl ~]# umount /mt 

{froot@linux1 -1# 


Tâche 7 : 
Modifier les paramètres du noyau. 


1. Créer des scripts 


a) Un script qui simule une application qui écrit sur disque. 

[root@linuxl ~]#- vi load output.sh 

#!/bin/sh 

GROSFIC=/usr/grosfic.dat 

for:-i-in-+-2-3-4.5:-67 

do 
dd if-/dev/zero of-SGROSFIC bs=1k count=100000 
rm. $GROSFIC 

donë 


b) Un script de surveillance de la mémoire. 
[rootêlinux] ~]# vi visu charge memoire.sh 
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#!/bin/sh 
À ELA A À er dE De VAN 
do 
clear 
date 
head -20 /proc/meminfo 
sleep 3 
done 


2. Activer les écritures disque et surveiller l’activité mémoire. 


a) Avant de changer un paramètre du noyau. 

[root@linuxi ~]# cat /proc/sys/vm/page-cluster 

3 

[rootêlinuxl -}# time sh load output.sh > /tmp/result 2>61 & 
[1732476 

[root@linuxl -]# sh visu charge memoire.sh 
Sun-Feb.4:18:17:36 CET 2001 


MemTotal: 449908 KB 
MemFree: 279088 KB 
Buffers: 4076-KkB 
Cached: 130568 kB 
SwapCached: 6032 kB 


b) Après (on prend l’exemple du paramètre page-cluster). 
[root@linuxi -]# echo 20 > /proc/sys/vm/page-cluster 
[root@linuxl -]# cat /proc/sys/vm/page-cluster 

20 


On refait l'exercice précédent. 


Tâche 8 : 
Simuler une charge avec un benchmark, l'influence de la mémoire 


On simule une charge Web avec l’outil ab (Apache doit être actif). 


[root@linuxl -]# /etc/init.d/httpd restart 

Arrâât de httpd : [ACHOUÂ] 

DÂmarrage de httpd : EOR] 
{root@linux1i -]# ab -c 20 -n 10000 'http://localhost/' 

This is ApacheBench, Version 2.0.41-dev <SRevision: 1.141 $> apache-2.0 
Copyright (c) 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/ 
Copyright (c) 1998-2002 The Apache Software Foundation, http://www.apache.org/ 


Benchmarking localhost (be patient) 
Completed 1000 requests 
Completed 2000 requests 
Completed 3000 requests 
Completed 4000 requests 
Completed 5000 requests 
Completed 6000 requests 
Completed-7000- requests 
Completed 8000 requests 
Completed 9000 requests 
Finished 10000 requests 
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Server Software: Apache/2.0.52 

Server Hostname: localhost 

Server Port: 80 

Document Path: 1 

Document Length: 5044 bytes 

Concurrency Level: 20 

Time taken for tests: 6.656780 seconds 

Complete requests: 10000 

Failed requests: 0 

Write errors: 0 

Non-2xx responses: 10010 

Total transferred: 52472420 bytes 

HTME transferred: 50490440 bytes 

Réquests per second: 1502:23-[#/sec]- (mean) 

Time per request: 13.314 [ms] (mean) 

Time per request: 0.666 [ms]: (mean; across all concurrent requests) 
Transfer rate: 7697.72 [Kbytes/sec] received 


Connection Times (ms) 
mäin mean(+/-sd) median max 


Connect: 0 A LT 5 23 
Processing: 4 7 SE 7 22 
Waiting: 1 BS Zeg 6 21 
Total: Nk trá Ee 30 


Percentage of the requests served within a certain time (ms) 


503 12 
66% 13 
75% 13 
80% 13 
90% 13 
95% 13 
98% 14 
99% 18 
100% 30 (1ongest request) 


froot@linuxl -]# 





Remarques : 


1) Dans l’exemple, la commande ab active 10000 requêtes HTTP, on active 20 requêtes 
simultatnément (cf. ab(8). 


2) On peut activer la commande ab à partir du poste en binôme. 





On réalise le test : 
a) En mode graphique avec 128 Mo de mémoire. 
b) En mode texte avec 129 Mo de mémoire. 


c) En mode graphique dans l’état par défaut du serveur. 








Remarque : Pour indiquer le niveau d’init et la mémoire, on édite la configuration Grub lors du 
démarrage, par exemple : 


kernel /vmlinuz-2.6.9-11.EL.smp ro root=LABEL=—/ rhgb quiet 3 mem=128M 
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